#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>

typedef struct
{
    int key; //查找表中每个数据元素的值
    //如果需要，还可以添加其他属性
} keyList;

typedef struct
{
    keyList *array; //存放查找表中数据元素的数组
    int length;     //记录查找表中数据的总数量
} SSTable;

//创建查找表
void Create(SSTable **st, int length)
{
    (*st) = (SSTable *)malloc(sizeof(SSTable));
    (*st)->length = length;
    (*st)->array = (keyList *)malloc((length + 1) * sizeof(keyList));
    printf("输入表中的数据元素：\n");
    //根据查找表中数据元素的总长度，在存储时，从数组下标为 1 的空间开始存储数据
    for (int i = 1; i <= length; i++)
    {
        scanf("%d", &((*st)->array[i].key));
    }
}

//查找表查找的功能函数，其中key为关键字
int Search_Seq(SSTable st, int key)
{
    //将关键字作为一个数据元素存放到查找表的第一个位置，起监视哨的作用
    st.array[0].key = key;
    //for (int i = st.length;st.array[i].key!=key ; i--)
    int i = st.length;
    //从查找表的最后一个数据元素依次遍历，一直遍历到数组下标为0
    while (st.array[i].key != key)
    {
        i--;
    }
    //如果 i=0，说明查找失败；反之，返回的是含有关键字key的数据元素在查找表中的位置
    return i;
}

int main()
{
    SSTable *st;
    Create(&st, 6);
    printf("请输入查找数据的关键字：\n");
    int key;
    scanf("%d", &key);
    int location = Search_Seq(*st, key);
    if (location == 0)
    {
        printf("查找失败");
    }
    else
    {
        printf("数据在查找表中的位置为：%d", location);
    }
    return 0;
}